package com.galaxy.coupon.domain.vo;

import com.alibaba.excel.annotation.ExcelProperty;
import com.baomidou.mybatisplus.annotation.TableField;
import com.galaxy.common.mybatis.core.domain.BaseEntity;
import com.galaxy.coupon.domain.UserCoupon;
import io.github.linpeilie.annotations.AutoMapper;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.util.Date;

/**
 * 用户优惠券视图对象
 */
@Data
@EqualsAndHashCode(callSuper = true)
@AutoMapper(target = UserCoupon.class)
public class UserCouponVo extends BaseEntity {
    private static final long serialVersionUID = 1L;

    /** 主键 */
    @ExcelProperty(value = "用户优惠券ID")
    private Long id;

    /** 用户ID */
    @ExcelProperty(value = "用户ID")
    private Long userId;

    /** 用户名称 */
    @ExcelProperty(value = "用户名称")
    private String userName;

    /** 优惠券ID */
    @ExcelProperty(value = "优惠券ID")
    private Long couponId;

    /** 优惠券名称 */
    @ExcelProperty(value = "优惠券名称")
    private String couponName;

    /** 优惠券编码 */
    @ExcelProperty(value = "优惠券编码")
    private String couponCode;

    /** 状态(0:未使用,1:已使用,2:已过期) */
    @ExcelProperty(value = "状态")
    private Integer status;

    /** 状态名称 */
    @ExcelProperty(value = "状态名称")
    private String statusName;

    /** 使用订单号 */
    @ExcelProperty(value = "使用订单号")
    private String orderNo;

    /** 使用时间 */
    @ExcelProperty(value = "使用时间")
    private Date useTime;

    /** 获取方式(0:系统发放,1:主动领取,2:积分兑换) */
    @ExcelProperty(value = "获取方式")
    private Integer getType;

    /** 获取方式名称 */
    @ExcelProperty(value = "获取方式名称")
    private String getTypeName;

    /** 获取时间 */
    @ExcelProperty(value = "获取时间")
    private Date getTime;

    /** 过期时间 */
    @ExcelProperty(value = "过期时间")
    private Date expireTime;

    /** 创建时间 */
    private Date createTime;

    /** 更新时间 */
    private Date updateTime;

    @TableField(exist = false)
    private CouponTemplateVo coupon;
}
